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I. INTRODUCTION 


The life expectancy of an aircraft is exceedingly 
difficult to estimate; but the importance of an accurate 
estimate demands that maximum effort be exerted. The cost 
of inaccuracy is measured in both lives and dollars; that is 
to say, there are costs associated with operating an 
aircraft beyond its life expectancy as well as failing tc 


operate an aircraft to the limit of its useful life. 


The fatigue life of an aircraft is dictated by the 
critical foints of the aircraft's structure, and is based on 
Cumulative damage theory. An estimate of the cyclic flight 
loads, which might be encountered by the aircraft, is us:d 
to meet fatigue life specifications in aircraft design. 
Current in-service monitoring of structural fatigue damaje 
is accomplished by a fleet-wide counting acceleromet2r 
program; however, under the same flight load, the actual 
strain experienced at a critical point will vary with 
Beemeeadit Welght, confaguration, and flight condition. The 
Fatigue monitoring data acquisition system was designed to 
gather significant strain information at the critical polits 
of the structure, to record the events in the sequence in 
Which they cccur, and to make the data thus gathered 


available for further analysis. 


The system which was develoved is comprised of two major 
subsystems: the WRITE supsystem and the READ subsysten. 
The WRITE subsystem is tasked with the airborne collection 
of data. It makes use of a microprocessor, various 
components for signal processing, a magnetic tave recorder, 


and a strain gage network to monitor strain-generated 





Signals, identify significant events, and record the 
collected data. The READ subsystem 1S tasked with the 
retrieval of the data from the WRITE subsystem recorder. A 
desk-top calculator and cassette tape reader accomplish this 
task, which includes the read-back of the magnetic tape, the 
pre-processing of data, and tke operation of a data file 


retrieval systen. 


A prototype system has been built and tested by 
controlling input Signals and comparing them with the output 
which was retrieved. Consistent data correlation indicated 
that the system is feasible. The employment of the systen, 
aS envisioned, 1s discussed herein, as well as the options 
which undoubtedly will exist with the rapid advance of 


Microcomputer technology. 
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The WRITE subsystem of the fatigue life data acquisition 
system is dedicated to the sensing of Significant strain 
events which have been experienced by the aircraft and the 
recording of those events. It includes various hardware 
components used to monitor, digitize, process and record 
signals which are generated by strain gages located at up to 
eight critical points of interest. The software package of 
the microprocessor controls the hardware components and 
monitors their functions. Screening, formatting, storing 
and recording of data are also functions performed by the 


software package. 


A. HARDWARE COMPONENTS 


fae SP'S—~803 microprocessor 


The MPS~-803 microprocessor is a microcomputer 
capable of handling data and performing arithmetic and 
logical operations. The microprocessor is physically 
comprised of three 4-1/2 inches by 6-1/2 inches printed 
Guecuit cards: the CPU card, the ROM/RAM card sand the 1/70 


Gard. 


Of greatest significance on the CPU card are the 
crystal clock, which provides the timing )-f0r ane 
microprocessor, and the 8008 CPU (central processing unit), 


which executes instructions located in the memory of the 
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microprocessor. The set of permissible instructions may be 
found in fhe Designer's Guide to Programmed Logic for MPS 
800 Systems [Biewer, 1974]. The executable instructions are 
generally arithmetic and logic operations, addressing of 


input/output ports and accessing of memory locations. 


The ROM/RAM card contains four PROMS (programmable 
read-only memory) and sixteen RAM chips (random access 
memory). Each PROM contains one page of memory storage for 
256 bytes of information. Each byte 1s an instruction word 
represented by an 8-digit binary number (8 bits). fThe four 
PROMS, collectively referred to as ROM, provide a total of 
1024 memory locations. The PROMs are the only non-volatile, 
unalterable storage in the microprocessor and are therefore 
the only suitable storage for the program instructions. 
This 1s virtually the only restriction on the size of the 
control program. The current program allows for at least 


one-half page expansion. 


The sixteen RAM chips on the ROM/RAM card represent 
2K (1K=219) memory locations. The RAM chips, collectively 
referred to as RAM, provide storage which is alterable by 
the CPU during the execution of the program. Consequently, 
the first page (256 bytes) of RAM is used for the storage of 
program variables, and the remaining seven pages (1792 
bytes) of RAM are available for data storage. Unlike ROM, 
RAM storage is volatile and cannot be retrieved after an 


interruption of power. 


The I/O card provides 28 TTL (transistor-transistor 
logic) compatible input/output lines. The circuits are 
selectable in groups of four to various combinations of 
input and output ports. The current configuration assigns 
the first eight lines to input port zero, the second eight 
lines to input port one, the third eight lines to output 


port two, and the remaining four lines to output port three. 
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2. AZD Signal Processing Module 


The analog Signals from the strain gages must be 
digitized in order to be analyzed and stored by the 
microprocessor. The signal processing module was designed 
ame developed by Lt. W.C. Stanfield, 0.S.N. { Stanfield, 
1976]. The module provides for multiplexing of eight input 
channels by a multiplexer, which is driven by a binary 
up-down counter. The counter provides the channel number, 
and the muitiplexer selects the channel. A sample and hold 
component is used to stabilize the voltage of the input 
analog signal, which allows signal digitization by the 
analog-to-digital converter (ADC). The resultant output of 
the ADC is an 8=bit binary representation of the analog 
input. The binary up-down counter and multiplexer are 
necessary only in order to allow monitoring of multiple 


Channels. 


The recorder employed is the Menodyne Model 171 
magnetic tape recorder. The Model 171 is a write-only 
{cecord-only), parallel data machine. The recorder inputs 
each data byte in 8-bit parallel form and formats the word 
into a serial format suitable for recording on the tape. 
The Model 171 achieves a recording density of 40 bytes per 
inch of magnetic tape (320 bits/inch). The magnetic tape 
used 1s a digital quality, standard size cassette with a 
length of 300 feet. This allows the recording of up to 
144,000 bytes (1,152,000 bits) on a single cassette. The 
nominal rated speed of recording is 100 bytes per second 


(800 bits/second); however, the developmental system was 
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consistently operated at 110-120 bytes per second without 
teeeiculty. 


4. Peripheral Inputs © 


ae Header switch 


The header switch is a two-position toggle 
Switch used to advance the tape beyond its leader and to 
write identifying information at the beginning of the tape. 
Activating the switch advances the tape, ensuring that the 
tape leader does not interfere with the recording process. 
This also provides a blank portion at the beginning of the 
magnetic tape and further reduces the uncertainty involved 
in locating the recorded data when attempting to read it 
back. Deactivation of the switch causes the header 
information to be written on the tape, and the system enters 


the data collection mode. 


b. Thumbwheel switches 


The thumbwheel switches are a series of Six, 
10-position switches. The six switches allow the 6-digit 
aircraft bureau number to be indicated. These switches then 
become a scurce for identifying information to be included 


in the header. 


Cc. Welght-on-wheels switch 


The weight-on=wheels switch 1s a two-position 
Sumieen, Which indicates that the aircraft is on deck or 


airborne by sensing the extension of the landing gear oleo. 
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The Switch is activated while the oleo is compressed, which 
indicates to the system that a removal of power may be 
imminent. The system responds by recording the data which 
are located in the volatile RAM to prevent its loss upon 


removal of power to the system. 








A -10 VDC power source is required for the MPS-803 
microprocessor, and a +5 YDC power source 1S required for 
the logic circuits of both the microprocessor and the 
Memodyne recorder. The recorder also requires a +12 VDC 
source for the motor drive circuit. The signal processing 
module also has unique power reguirements for +15 VDC and 
~15 VDC. (Refer to figures 1 through 3.) 


B. SOFTWARE PACKAGE 


The WRITE system software package is a single program of 
instructions fOr the $008" “CPU. The total number of 
instructions is less than 1000 words, which are stored in 
the four PROMS of the 4?S-803 microprocessor. The program 
WaS written in PL/M, a higher-level programming language for 
Microprocessors, and converted to 8008 instructions by the 
PLM8 compiler, a resident program on the Naval Postgraduate 
School IBM~-360 computer. The INTELLEC 8 microcomputer was 
used as the means for programming the PROMS and was aiso 
used aS a developmental tool to simulate the MPS-803 
Microprocessor, since both utilize the 8008 CPU and 8008 
instruction set. The software package is listed in Appendix 
A, and additional information on PL/M is included in 


Appendix B. See flowchart in figure 4. 
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The Pape Sit step of the program starts an 
initialization process which assigns the desired initial 
values for various variables used later in the program. 
Because the program operates by comparing successive signal 
inputs, the initialization provides for the first sampling 
of each channel to be stored in order to establish a basis 
ond comparison POG Subseguent samplings. After 
initialization the system enters a repetitive process, which 


will continue until the removal of power. 


The header switch 1s examined to determine its 
status. If it has been activated, the recorder motor drive 
is energized to advance the tape for approximately nine 
seconds, which is sufficient to ensure that the head of the 
recorder 1S positioned beyond the tape leader. Upon 
deactivation of the header switch, the thumbwheel switches 
are examined and the header information derived is recorded 


on the tape. 


The weight-on-wheels switch is then examined. An 
activated switch indicating the aircraft is on deck causes a 
programmatic timer to be started which provides for the 
recording of data at intervals of 30-35 seconds in order to 
prevent loss of data in RAM upon removal of power. An 
airborne indication results in the normal continuation of 
the program, which provides for the recording of data only 


when the RAM capacity has been exceeded. 


After the switches have been examined, the signal 
input channels are multiplexed. Each channel's signal is 
compared with its previous sample. If, as a result of this 


comparison, it is determined that no changes have occurred; 
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then the program continues by re-examining the header and 
weight-on-wheels switches and re-sampling the signal input 


channels repetitively until a change is identified. 


The change of a signal is the first indication that 
an event may be strain significant. The sign of the slope 
of the change is determined and compared with the sign of 
the slope of the previous change. Any change in sign will 
identify a peak or a valley in the analog signal and is 
further indication that a strain-significant event may have 
occurred. Furthermore, to be significant, the value of the 
strain reading must be above a predetermined positive 
threshold or below a predetermined negative threshold. To 
aid in the analysis of the data, the first peak or valley 
following a strain-significant event is considered to he 
Significant regardless of the threshold CLIteEton. 
Consequently the threshold criterion functions to replace 


multiple occurrences within the threshold by a single event. 


The mechanics of the software that accomplished this 
task 1s based on Four 8-element vectors. The four vectors 
are used to keep track of four variables associated with 
each of the. eight signal input channels. Th2y are as 
follows: | 

X(CHANNEL): the current value of the signal on 
the channel designated 

XLST (CHANNEL): the previous value of the signal 
on the channel designated 

SLST (CHANNEL): the sign of the of last change of 
the signal on the channel designated (0 neans 
negative slope; non-zero means positive slop) 
FLAG (CHANNEL) : an indicator showing the status of 
the last strain-significant event (0 means within 
the threshold; non-zero means outside the 
threshold) 
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Once a signal has been determined to be a 
strain-significant event, it is identified by channel number 
and stored in RAM. If an event fills the last storage 
location in RAM, the recording procedure is initiated. The 
seven pages of RAM containing the data words are transferred 
byte+by-byte to the recorder and written on the magnetic 
tape. The transfer takes slightly more than fifteen 
seconds, during which time the signal input channels are not 
monitored. Upon completion of the transfer, the seven pages 
of RAM are free to be refilled. 


ae INITIALIZE 


The first procedure encountered in the execution 
of the program is INITIALIZE. The first location in RAM 
which is to be used for the storage of data is identified as 
the hexadecimal address 0900H and the timer is set to Zero. 
(Refer to Appendix A.) 

RAMSLOC=0900H; 

TIMER=0; 
The MUX procedure is then used to fill the X(CHANNEL) vector 
With the first sample of the incoming signal, which is 
transferred to the XLST(CHANNEL) vector. The SLST (CHANNEL) 
and FLAG (CHANNEL) vectors are set to zero and initialization 


is complete. 


b. MUX 


The MUX procedure is used to multiplex the eight 
Signal input channels and fill the X(CHANNEL) vector with 
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euerent values. The first command 1S an output instruction 
which causes voltages to be applied to the output port 
selected in the pattern which is indicated. (Se2 Appendix 
Be.) The instructions 

OUTPUT (2) =408; 

OUTPUT (2) =0; 
cause output port 2 line 7 to receive a HIGH pulse. A HIGH 
pulse on that line is the signal which causes the binary 
up-down counter to reset and results in the aultiplexer 
selecting channel 0. Then for channels 0 through 7 the 
procedure which follows 1s performed. A pulse is created on 
output port 2 line 1 indicating to the analog-to-digital 
converter to commence conversion. 

OUTPUT (2) =1; 

OUTPUT (2) =0; 
The next software device is used in several places in the 
progran to wait fOr a Dartvcular input to the 
microprocessor. The statements 

DO WHILE NOT (ROL (INPUT (1)); 

END; 
cause the system to wait until an end-of-convert signal is 
received from the ADC, which indicates that the result of 
the conversion is available and valid. The value of the 
conversion is received on input port zero. 

K=INPUT (0) ; 
The binary up-down counter increment line is pulsed causing 
the next channel to be selected. 

OUTPUT (2) =80H; 

OUTPUT (2) =0; 
Attention is then returned to processing the signal which 
was just received. The resolution of the ADC exceeds the 
requirements for an adequate strain monitoring systen; 
consequently the 8-bit signal can be reduced to the five 
most Significant bits with the other three bits to be used 
later for channel identification. The next three statements 


are used to perform a rounding off of the 8-bit word by 
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adding the bit in the third position from the right to the 
bit in the fourth position. 

L=K AND QO4H; 

L=SHL (L,1) 3 

K=K+L 
For example, 1000$0101B would be rounded up to 1000$1000B, 
while 1000$0011B would be rounded down to 1000$0000B. The 
five most Significant bits are then shifted to the right and 


stored in the X vector. 


c. STORE 


If an event is determined by the main program to 
be strain significant, the STORE procedure is called. First 
the data word is assembled by placing the binary 
representaticn of the number of the channel from which the 
Signal was received in the upper three bits of the data word 
- (LASTX) . The data word already contains the signal value in 
the lower five bits. It is then inverted bit-by-bit (which 
will later facilitate reading) and stored in the RAM 
location which 1S currently indicated by the value of 
RAM$LOC. The variable name EVENT has been assigned to the 
current location. 

EVENT=NOT(LASTX OR ROR (CHANNEL,3)) ; 
The FLAG (CHANNEL) is then set to indicate if the event was 
Within oor without the threshold limits according to the 
convention previously described. 

FLAG (CHANNEL) =( (LASTX>POS$THRESH) 

OR (LASTX<NEWSTHRESH) ) ; 

The RAM location is then incremented. 

RAMSLOC=RAMSLOC+1; 
If the RAM capacity has been exceeded then the RECORD 
procedure is invoked prior to returning. 

IF RAMSLOC>=1000H THEN CALL RECORD; 
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d. RECORD 


The number of data bytes to be recorded is 

determined from the RAM location indicator. 

COUNT=RAMSLOC~-1; 
The BYTESRECORD procedure is invoked the correct number of 
times to record each data byte. 

DO RAMSLOC=0900H TO COUNT; 

CAE SY TeSRE CORD: 

END; 
A small blank portion of tape terminates the block of data 
bytes and is created by invoking the GAP procedure. 

CALL GAP.(80H) ; 
Before terminating the RECORD procedure, the RAM location 
indicator is set to QO8FFH. 

RAMSLOC=O08FFH; 
This is an indication to the main program that an 


initialization process will be necessary. 


eS. ove REGORD 


Fach time that the BYTE$RECORD procedure is 
invoked, a single data byte is recorded on the magnetic 
tape. First the data byte is latched in output port two, 
which is connected to the data input lines of the Memodyne 
recorder. 

OUTPUT (2) =EVENT; 
A pulse on line 4 of output port three indicates to the 
recorder that the data byte on its input lines is ready to 
be recorded. 

OUTPUT (3) =08H; 

OUTPUT (3) =0; 


A time delay of approximately seven milliseconds is invoked 
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before the procedure is terminated in order to allow the 
recorder to complete the recording process. 
CALL DELAY (778); 


The GAP procedure is used to write blank 
segments on the magnetic tape. The placing of line 3 of 
output port three in a HIGH status 

OUTPUT (3) =O48; 
causes the Memodyne recorder to LOAD FORWARD, a condition in 
which the recorder motor drive is activated but data is not 
written on the tape. A time delay is invoked 
CALL DELAY (N) ; 
where N is replaced by the value in the CALL GAP (N) 
statement. Then the LOAD FORWARD command is removed. 
OUTPUT (3) =0; 


g. DELAY 


Only one executable statement is used in <the 
DELAY procedure. 
CALL TIME (VAL) ; 
TIME is not a true procedure but rather a pre-defined 
function of PL/M which provides for a time delay. The DELAY 
procedure prevents multiple use of the TIME function and has 
the seemingly paradoxical result of reducing the number of 


instruction steps in the amachine language progran. 


h. HEADER 


The activation of the header switch causes the 


HEADER procedure to be invoked. Multiple calls of the GAP 
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procedure cause the tape to be advanced for approximately 
nine seconds. 

DOSK= 1 TO 3; 

DO J=1 TO 150; 

CALL GAP (255) ; 

END; 

END; 
The program enters a waiting condition which is terminated 
When the header switch is deactivated. 

DOGWNHILE ROL (INPUT (1) ,.3): 

END; 
Then the thumbwheel select variable C is initialized to zero 
in preparation for use in the READ procedure. 

Cc=0- 
The information to be written in the header is eight data 
bytes. Currently the first five bytes are not used. Each 
is programmatically filled with 80H and is available for 
future implementation. 

DO RAMSLOC=0900H TO O9044H; 

EVENT=808; 

END; 


The remaining three bytes of the header are 
filled with the Six digits of the aircraft bureau 
number--each half of a byte Son caanang the binary 
representation of a decimal digit. The READ procedure is 
used to singly interrogate each one of the six thumbwheel 
Switches and, unlike the other procedures, returns a value 
each time 1t is invoked. Because it returns a BYTE value, 
the procedure name, READ, is used as though it were a BYTE 
Variable (in contrast with the conventional procedure CALL 
Statement) with each appearance of the name READ being 
replaced by the value returned. 

DOD RAMSLOC=0905H TO 0907H; 
EVENT=NOT(SHL (READ,4) +READ) ; 
END; 
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The RAM location indicator is then adjusted properly for 
invoking the RECORD procedure, and the call is made. The 
eight data bytes of the header are recorded on the tape and 


the RAM location indicator is reset in preparation for data 


collection. 
RAMSLOC=0908H; 
CALL VR ECORD: 
RAMSLOC=0900H; 
i. READ 


Each time that the READ procedure is invoked a 
thumbwheel switch is selected and the position of the 
thumbwheel switch setting is returned aS a BYTE value. The 
first execution of READ is with C=0, which results in the 
thumbwheel switch corresponding to zero of select lines 2, 3 
ama@m4 Of Output port two. 

OUTPUT (2) =C; 


The variable C is then incremented such that the next output 


\ 


of C will result in the bit pattern 001 appearing on lines 
4,3 and 2 respectively. 

C=C+2; 
Then the thumbwheel switch setting is obtained from input 
Pomemmone, lines 1 through 4, and returned. This value is 
the inverted binary representation of the decimal digit 


indicated on the face of the thumbwheel switch. 
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Ei Euec us READ SYSTES 


The READ subsystem of the fatigue life data acquisition 
System is dedicated to the reading (or playback) of the 
Magnetic tape created by the WRITE subsystem. Its functions 
include reading, re-formatting, sorting, filing and file 
retrieval of the data on the magnetic tape. These tasks are 
accompiished with a minimum of hardware complexity and 


lengthy, but relatively uncomplicated, software. 


A. HARDWARE COMPONENTS 


1. Memodyne Recorder 


The recorder employed is the Memodyne Model 172 
Magnetic tare recorder. The Model 172 is a read-only 
(playback-only), parallel data machine. The recorder reads 
the data in eight bit segments from the tape and assembles 
the word into an 8-bit parallel format. The nominal rated 
speed of reading is 80 bytes per second (640 bits/second) ; 
however, the developmental system was operated at 


approximately 25 bytes per second. 


The Hewlett-Packard Model 9830 Calculator is the 
main computing component of the READ systen. Hie SNS crcl S18, 


calculator is small enough to be used on a desk top and may 
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be configured to accept electrical power from various 
sources including 110 VAC or 220 VAC. The HP 9830 is 
programmable from its typewriter-like console or from 
Magnetic tafe files. The magnetic tape file system is a 
built-in read/write cassette recorder, which allows storage 
of program files and data files on a digital quality, 
standard size cassette. The proprietary nature of the file 
Operating system prevents the use of the built-in recorder 
for reading of cassette files that have been created by 


machines other than the HP 9800 Series. 


The HP 9830 calculator may be equipped with various 
peripheral devices.’ These devices include, among others, 
printers, x-y plotters, card readers, teletypewriters, paper 
tape readers and external cassette tape recorders. The use 
of most peripheral devices requires installation of the 
Extended Input/Output Read-Only Memory, which is a 
uSer-accessible plug-in device. Utilization of the software 
package on the HP 9830 requires 4K of augmented memory and 


the Matrix Operations Read-Only Memory. 


Bemeetke HP 142¢2" TTL 170 


The Hewlett-Packard TTL [I/O Parallel Interface 1s 
also required to allow the transfer of data between the HP 
9830 and a peripheral device in an 8-bit parallel format. 
The parallel interface is a plug-in module which physically 
connects the I/O lines of the HP 9830 and, in this 
application, the I/O lines of the Memodyne recorder. The 
successful mating of the AP 11202A TTL I/0 Parallel 
Interface to the Memodyne recorder was primarily due to the 
efforts of Lcdr. John R. Plunkett, U.S.N. 
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Bee LHE SOFTWARE PACKAGE 


The READ system software package consists of two 
separate programs: a read/store program and a file 
retrieval program. Both programs are written in BASIC, a 
programming language which is directly executable on the 4HP 
9830 without the requirement for external cross-compilation 
on a larger computer. The read/store program reads data 
from the external Memodyne cassette recorder and creates 
data files on the HP 9830 built-in cassette recorder. The 
file retrieval program provides for selective retrieval of 
data files from the HP cassette for data display ofr 
Manipulation. The software package is listed in Appendix C, 
and additional information on BASIC is included in Appendix 


D. See flowcharts in figures 5 and 6. 


a. Operation of the program 


After the program has been loaded from the HP 
cassette file, the user nay start the program py pressing 
RUN and EXECUTE. The initialization process is used to 


dimension the variabke arrays and assign initial values. 


The user is then instructed via the line printer 
to prepare the Memodyne recorder by holding the STOP key 
depressed until the clear leader on the Memodyne cassette 
has been advanced beyond the photoelectric sensing device of 
the recorder. Fallure to do SO will prevent the 


programmatic Operation of the recorder. The user is 
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additionally instructed to continue program execution by 
pressing CONT and EXECUTE. 


Upon continuation of the program, the header 
information is read from the data tape, translated and 
printed on the line printer. Pollowing initialization of 
variables, the user 1S requested to input the number of 
pages of data to be read. A page is defined to be 256 data 
bytes, which corresponds to the size of a page of memory. 
Then, in page increments, the data 1s read from the data 
tape, translated, sorted by channel and stored in the HP 
9830 memory. When 100 events corresponding to ae single 
channel have been assimilated, the events are recorded on 
the HP cassette, thus freeing 100 memory locations. At the 
completion of the translation of the last page, all events 
are recorded py channel on the HP cassette even though each 


channel contains less than 100 events. 


b. Header 


The fest step in translating the header 
information is the inputting of additional identifying 
information. AS an example of the type of identifying 
information which could be used, the entering of the date, 
1n numerical form, is requested of the user. 

DUSPeU ENTER DA pNO, TR -SPAZO: 

INPUT N1,N2,N3 
Then the first eight bytes on the data tape are read into 
the Z vector which is used for storage of unprocessed data 
words. 

FOR N=1 TO 8 

Z(N) =RBYIE7 

NEXT N 
The RBYTE7 ccmmand is the instruction which causes the dP 


11202A parallel interface to obtain a single byte of data 
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from the Memodyne recorder. The interface initiates the 
read process by pulsing its CONTROL line, which is connected 
to the START line of the Memodyne recorder. The interface 
then monitors its FLAG line which receives the signal that 
the Memodyne recorder has read a byte of data and has 
latched it on its output Ilines. The data byte is then 


received by the calculator and stored in memory. 


The first five bytes of the header information 
have not been used by the WRITE system and are ignored by 
the READ systen. The remaining three bytes contain the 
binary-~coded decimal representation of the six digits of the 
aircraft bureau number. The translation of these three 
bytes requires considerable bit manipulation. The first of 
these bytes corresponds to N=6. The statements 

M1=BIAND (Z(N) , 240) 

M1=ROT (M1,4) 
Causes the upper four bits to be converted to a decimal 
aug vt. Multiplying the digit by ten effectively places it 
in the tens position, and then it is added to the bureau 
humber which is being constructed. 

M1=10*M1 

MO=MO+M1 
MO is initially zero. The lower four bits are similarly 
translated, but remain in the ones position, and are added 
to the bureau number. 

M1T=BIAND(Z(N) , 15) 

MO=MO+1 


The bureau number is now a two-digit decimal 
number. The next data byte is identically processed to 
provide the next two digits but first it is necessary to 
multiply the current two-digit bureau number by 100, which 
effectively shifts the digits to the left by two positions. 

MO=100*#0 
After the next two digits have been added, but before the 


i 
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translation of the last data byte, the bureau number is 
again shifted left by two positions allowing the remaining 
two digits to be added to the bureau number; then the bureau 
number and additional header information is printed on the 
line printer. 

PRINT "BONO=""s5M0,"DA/MO/YR="3N13N23N3 


c. Data reading and translation 


After the re-initialization of variables and the 
number of pages of data to be read has been entered, 
successive pages of data are read from the data tape, 
translated and stored. 

| FOR I=1 IT0 256 
Z(N) =RBYTS7 
NEE of 


The translation process isolates the three 

uppermost bits which contain the channel number. 

J=BIAND (Z (I) ,224) 

J ROL eS) 
Because of the use of PL/M by the WRITE system and the use 
of the binary up-down counter for selection of channels, it 
Was convenient to number the eight signal input channels 
from zero through seven. BASIC, on the other hand, is more 
practically employed if the channels are lettered A through 
H and numbered correspondingly one through eight. The 
converting of the translated channel number from one scale 
to the other is trivial but necessary. 

J=J+1 


The value of the data word is found by isolating 
the five lowermost bits. 
V=BIAND(Z (I) , 31) 


The use of PL/M precluied the effective use of signed 
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arithmetic in the WRITE system. However, BASIC allows the 
use of negative numbers with greater ease, which prompts a 
re-scaling of the strain values. The WRITE system uses a 
scale with 0 and 32 as extrema, where 16 corresponds to the 
unstrained state. For the READ system it is convenient to 
shift the scale such that the unstrained state corresponds 
to zero, and the extrema are -16 and +16. Again the actual 
conversion is trivial. 

V=V~- 16 
Fach value is stored by a subroutine which corresponds to 
the channel number. 

GOSUB J OF 4100,4200,. . .,4800 


d. Data storage 


Each of the eight subroutines, corresponding to 
the eight channels, performs a Similar storage task. 
Associated with each subroutine is a vector of 100 elements 
and an index which identifies the element. The vector names 
are A through H, and the indices are Nit through N& 
respectively. The first subroutine will be used as an 
example. Each time a value is to be stored in the A vector, 
the subroutine at line 4100 is invoked. The value is stored 
at the current element location, and the index 1s 
incremented in preparation for the next element to be 
entered. 

AC N1J=V 

NI=N1+1 
If the vector capacity has not been exceeded; then the 
Subroutine task is complete. 


IF N1#101 THEN 4199 


- ‘ 


4199 RETURN 
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If the vector capacity has been reached then it is necessary 

to perform a preliminary task which results in the 

asSignment of a file number for the recording of the vector 

on the HP cassette. This 1s accomplished by a subroutine. 
GOSUB 7000 


After a file number has been determined the 
STORE DATA statement may be executed. 
STORE DATA 41,A 
This statement causes the elements of vector A to be stored 
on the HP cassette in a data-type file, whose number 


corresponds to the variable M1. 


The index and vector are then re-initialized to 
allow refilling of the vector. 
N1=1 
MAT A=ZER 
The data storage task is then complete, and the program 


returns to translate the next data word. 
e. Data file system 


The data file system consists of a series of 
consecutively numbered files, each file being 400 bytes in 
length and containing a 100-element vector. The seemingly 
excessive file length is required for data-type files. The 
files are filled in numerical order as each vector in the 
Main program reaches 1ts storage capacity. An additional 
vector, L, serves as a directory, which is a list of channel 
humbers corresponding to the sequence in which the data 
files were created. The directory vector is indexed by the 


Variable N. 


The variable M0 is used to identify the file 


humber corresponding to the first data file which is 
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reserved for the directory. The variable M1 is the file 
number of the current file. Since files 0 and 1 contain the 
READ system software, file 2 is the first available data 
file. Consequently MO and M1 are initialized with the value 
Ze 

MO=M1=2 


Fach time a vector is to be stored, the 
subroutine beginning at line 7000 is invoked prior to 
storing the vector. The channel number of the vector to be 
stored is entered in the directory according to the current 
index, and the index is incremented in preparation for the 
next directory entry. 

ened 

N=N+1 
The current file number is incremented to the next available 
fae 

M1=M1+1 
pfebre)al the directory entry made and the current file 
identified, the program continues execution with the storage 


of the appropriate vector. 


After the last page of data has been tread, 
translated and stored, it is necessary to file the partially 
filled vectors. This is done by artificially saturating the 
vectors and sequentially invoking each storage subroutine an 
additional time. 

V=100 
N1=N2=N3=N4=N5=N6=N7=N8=100 
FOR J=1 TO 8 
GOSUB J OF 4100,4200,. . .,4800 
NEXT J 
Finally, the directory vector must be stored in the data 
file which has been reserved for that purpose. 
. STORE DAFA M0O,L 


a2 


2. File Retrieval Program 


The file retrieval program allows the user to 
selectively retrieve and examine the data files which have 
been created by the READ/STORE program. 


After the program has been loaded, the user may 
start the program by pressing RUN and EXECUTE. Cine 
initialization process allocates storage for two 100-element 
vectors: L, the directory vector, and X, the vector to be 
examined. The variable M is also initialized with the file 
number of the data file containing the directory. Then the 
directory file is loaded from the HP cassette into the 
memory storage which nas been allocated for the L vector. 

DIM L{ 100], xX[{ 100] 

M=2 

LOAD DATA 4M,L 
The user is requested to designate a channel number in the 
range from one to eight. The channel number is echoed back 
on the line printer. 

DiPore VENTER "CHAN NED Oca( 1=S)"s 

LeU Cc 

Pett  'GHANN DE: Coit Wi 
Then the directory 1S sequentially searched for entries 
corresponding to the channel number which has been selected. 
Each occurrence of the channel number in the directory 
causes a subroutine to be invoked. The directory elements 
following the last valid entry will each be equal to Zero. 
Consequently, encountering a zero entry in the directory 
indicates that the directory search is complete with respect 
to all valid entries. The directory search is subsequently 
terminated and the program returns to request that another 


Channel ‘number be entered. 
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FOR N=1 TO 100 
IF L{N]#C THEN 90 
GOSUB 120 

90 IF L{[N]=0 THEN 35 
NEXT N 


The subroutine beginning at line 120 is an example 
of the method used to access specific data files. The file 
number of the data vector to be examined is calculated by 
the location of the channel number (N) in the directory and 
the offset (M) due to the location of the directory file. 
The data file is then loaded into the available vector 
storage. 

LOAD DATA NtM,X 
In this example, the file is Simply printed on the line 
printer ina 10 by 10 array before returning to execution of 
the main progran. 

POR f=" 610 91 STEP 10 

PRINT X(I) 5X (I+1) ;X(I+2)3. . «3X (+9) 

HEAT 1 
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The testing of the fatigue monitoring data acquisition 
system was conducted in a laboratory environment at the 
Naval Postgraduate School. Channel 1 of the signal input 
channels was connected to ground, and the remaining 7 
channels were connected to known signals. Channels 2, 3, 
and 4 received a Sinusoidal signal with amplitude of +3.7 
volts. Channels 5, 6, 7, and 8 received an oscillating 
Signal of variable amplitude between +5 volts. The rate of 
occurrence of significant events was controlled by selecting 
the frequency of oscillation. The measurement of the 
elapsed time between input of the data and transfer to the 
magnetic tape. was consistent with the known occurrence rate 


of the peaks and valleys of the input signal. 


The reading of the data tape further confirmed the 
operation of the fatigue monitoring data acquisition system. 
Channel 1 was determined to be void of strain-significant 
occurrences. Channels 2, 3, and 4 exhibited an alternating 
Signal of +12 and -12 which corresponds to approximately 
Homose Volts. Channels 5, 6, 7, and 8 exhibited data which 
was consistent with the general oscillatory signal on the 


corresponding signal inpst lines. 


The analog input signal on channel 2 was 3.7 volts, and 
the fatigue monitoring data acquisition system processed the 
Signal resulting in the value 12. The ADC outputs digital 
values on a scale 000050000B to 111151111B corresponding to 
input voltages in the range of +5 volts, with 1000$0000B 
corresponding to zero volts. Since 3.7 volts is .74 of 5 


volts, the ADC should output the binary value corresponding 
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to .74 of the digital scale above 1000$0000B. That value is 
1101$1111B. The rounding off by the WRITE system software 
results in the value 1110$0000B. Then the value is shifted 
right three bit positions yielding 0001$1100B. The 
READ/STORE program interprets this value as its decimal 
equivalent 28. This value is re-scaled to place zero in the 
center, corresponding to zero strain, by subtracting 16, 
which results in the final value of 12. The value 12 is 
representative of .75 (12/16) of 5 volts, which is 3.75 
volts. The values 11 and 13 would represent 3.44 volts and 
4.06 volts respectively; so 12 actually represents 3.75+.15 
volts, which is consistent with the analog value of 3.7 


volts. (Refer to figures 7 and 8.) 
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V. OBSERVATIONS 


A. MICROVOX RECORDER VERSUS MEMODYNE RECORDER 


A successful WRITE system was designed and developed by 
ihe Wesley C. Stanfield utilizing a Microvox Corporation 
digital wafer tape recorder and the MPS-803 microprocessor. 
The Microvox recorder is considerably smaller than the 
Memodyne recorder, and its advantages are described in 
"Microprograammable Integrated Data Acquisition Systen: 
Fatigue Life Data Application" [Stanfield, 1976]. 


The attempted development of a Microvox READ system met 
With only limited success. After considerable effort and 
time, a Microvox read-only recorder was mated to the 
INTELLEC 8 microcomputer. The operation of the Microvox 
reader appeared to be satisfactory enough to identify some 
problem areas between the READ system and the WRITE system. 
The Microvox digital wafer is a continuous tape, which is 
Similar in design to tape cartridges. The nature of a 
continuous tape allows the obliteration of previously 
recorded data if the tape is run beyond one full cycle. 
This necessitates careful identification of the beginning 
and end of tape. Attempts to modify the Microvox WRITE 
system to achieve compatibility with the requirements of the 
READ system resulted in repeated difficulty in obtaining 
consistent, reliable operation primarily due to the problems 
encountered in the interfacing of the various hardware 
components. Output Signals were consistently weak making 


sensing of beginning of tape and end of tape unreliable and 
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intermittent. Use of the Microvox recorder was ultimately 
terminated by mechanical failure of the write-only recorder. 
The failure was the separation of the motor drive belt 
without which the tape drive capstan cannot rotate. The 
motor drive belt from the read-only recorder was also found 
to be worn. At this stage it seemed impractical to continue 


trying to implement the Microvox systen. 


After attempting to use the Microvox recorder, the 
Memodyne cassette recorder was once again utilized for 
incorporation into the fatigue monitoring data acquisition 
system because it was immediately available and had already 
been mated to the INTELLEC 8 in both the read and write 
modes. The Memodyne recorder had already been flight tested 
in a light aircraft (CESSNA 310) ina less demanding data 
acquisition application. In short, the reliability of the 
Memodyne recorder was considered to be less questionable 


than that of the Microvox recorder. 


The Memodyne recorder cassette has 3-1/2 times the 
Capacity of the Microvox recorder and its associated digital 
wafer. The Memodyne recorder is slower than the Microvox 
recorder, but the difference is virtually eliminated due to 
the requirement of the microprocessor to serially format 
each data word for transfer to the Microvox recorder. The 
Memodyne recorder, on the other hand, receives data words in 
8-bit parallel format and performs its own serial 
formatting. The Memodyne recorder does not utilize a 
continuous tape requiring location of beginning of tape and 
end of tape, which contributes to some degree of decreased 
complexity but also contributes to increased weight and 
size. The sophistication of the Memodyne recorder's 
formatting system is also a contributor to increased size 
and weight in comparison with the Microvox recorder. Even 
at this the Memodyne recorder is 3-3/4 inches by 4-1/2 


inches by 7 inches and weighs 4-1/2 pounds. 
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Be. THE 3080 CPU VERSUS THE 8008 CPU 


The MPS-803 microprocessor is capable of being expanded 
to include another 1K of ROM and an additional 2K of RAM; 
however the capabilities of the 8008 CPU make it possible to 
address a memory as large as 16K. Expansion of the system 
to the limits of the 8008 CPU's capabilities would increase 
the storage available for data collection by over eight 
times the capacity of the current system. The 8080 CPU can 
increase the addressability of memory to 64K. Over 35 times 
the current memory capacity for data collection would be 


available. 


The advantage of increasing the memory capacity is that 
if the solid-state memory is large enough, the need for an 
airborne magnetic tape recording device is eliminated. The 


volatile nature of random access memory is still a 


consideration, for it would require continuous power; 
however technological advances may soon relieve this 
requirement. 


C. RECOMMENDATIONS 


1. Memory 


The objective of the current WRITE system is to 
provide for multiple flights between ground servicing. if 
the magnetic tape recorder could be replaced by solid-state 
memory, a benefit could possibly be realized in weight 


Savings but, more important, reliability could be increased. 
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The operation of the tape recorder in extreme temperatures 
and under adverse G loadings is suspect. A solid-state 
memory would be able to function ina much greater range of 
environmental conditions. 

It is believed that it is within present-day 
capabilities to develop a system with a random access memory 
that can be battery-powered for a limited period of time. A 
non-volatile RAM manufactured by the Monolith Systems 
Corporation , according to its specifications, would be able 
to retain its contents for up to five months without 
recharging its batteries. A 16K memory of this type would 
weigh approximately six pounds with batteries and cost 
$2400. The cost of such a system is estimated to be twice 
the cost of the current WRITE system, which is approximately 


$1600 for component costs. 


Other non-volatile, random access memory systems are 
currently under development. Until a mass-marketed, 
non-volatile random access memory is available, the most 
practical solution seems to be the expansion of memory to a 
size great enough to permit the collection of data for a 
Single flight without exceeding the capacity of the RAM. 
The cassette tape recorder would continue to be an integral 
part of the system, but operation could be limited to the 


weight-on-wheels condition. 


A reasonable, if not conservative, way to estimate 
the number of strain Significant events, which might be 
expected over a specified length of time, is to refer to the 
structural design specifications for military aircraft. 
Table II of MIL-A-8866(ASG) specifies the frequency of 
manuever loads, which an aircraft must be able to sustain. 
An analysis of the most demanding Spectrum, that of fighter 
aircraft with respect to strain-significant events, reveais 


that no more than 26,000 occurrences per 1000 flight hours 
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should be experienced. Based on the quarterly report on the 
"Aircraft Structural Appraisal of Fatigue Effects (SAFE) 
Progran,' Naval Air Development Center, Warminster, 
Pennsylvania, average aircraft usage rates for various 
models of A-6, A-7, and F-4 aircraft indicate a mean usage 
rate of approximately 25 flight hours per month. This 
implies that, statistically, an aircraft might be expected 
to experience 650 strain-significant events each month. 
Under these circumstances a fatigue monitoring data 
acquisition system with eight channels would have a_ storage 


requirement for 5200 data words (slightly more than 5K). 


It must be acknowledged that determining storage 
requirements by this method is crude and imprecise, but 
establishing the validity of a statistical model of the time 
distribution of strain-Significant events would most likely 
be very difficult. To achieve some confidence that enough 
storage is available to allow for deviations from the mean 
values cited, it is estimated that three times the mean 
requirement is needed. The current WRITE system requires 
1.25K for program and variable storage, which would leave 
14.75K available for data collection if an 8008 CPU were 
used to itS maximum capacity. This would be marginally 
adequate at best, whereas if the 8080 CPU were used 62.75K 
fatigue Significant events could be recorded. Either system 
would experience a Similar weight and volume growth with the 
expansion of memory. This weight and volume growth would be 
approximately linear with incremental additions of 4K of 


memory. 


Two options, which should be considered, involve the 
alteration of the criterion used to determine the service 
interval of the system. If the service interval were based 
on a flight-hour cycle rather than a calendar cycle, the 
sensitivity of storage requirements with respect to aircraft 


usage rates could be eliminated, and the cycle could be more 
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readily tailored to individual aircraft models and missions. 
The sensitivity of storage requirements with respect to the 
frequency of occurrence of strain-significant events could 
be eliminated if the available storage were directly 
monitored. For example, in the current WRITE system, the 
cassette tape could be visually inspected as a part of the 
daily inspection and replaced as required. In the case of a 
completely solid-state RAM storage system, an external 
indicator could be displayed when the memory has exceeded 
some predetermined saturation level. The level could be 
determined to allow daily inspection as well as sufficient 
leeway to permit subsequent flights before servicing of the 
system is absolutely required. 


The Memodyne recorder is preferred over the Microvox 
recorder for reasons which have been previously discussed. 
The Model 171 write-only, parallel data recorder is 
recommended for the WRITE system, and the Model 172 
read-only, parallel data recorder is recommended for the 
READ system. The parallel data input/output is a very 
Significant feature, which reduces software requirements in 
the WRITE system and greatly reduces both hardware and 
software requirements in the READ system. Other models of 
Memodyne recorders are available, which are capable of 
increased storage capacity but at the sacrifice of speed. 
The 100 series recorders have adequate tape storage 
capacity. Because the data collection process must be 
interrupted to perform the data transfer from RAM to the 
Magnetic tape, any increased capability that sacrifices 


speed must be considered detrimental to the overall systen. 
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The system is designed to function between calendar 
inspections without any routine servicing required. An 
unused cassette is placed in the recorder, the tape having 
been fully rewound to the beginning leader. The power to 
the system is turned on, and the header switch is placed in 
the UP position. The tape motor will then advance the tape 
for a period of 7 to 10 seconds and stop. The thumbwheel 
Switches may be checked against the aircraft bureau number 
while the tape is advancing. Only after the thumbwheel 
Switches have been set should the header switch be placed in 
the DOWN position. Placing of the switch in the DOWN 
position causes the almost indiscernable movement of the 
tape, which is the recording of the header information. The 
header switch may be placed in the DOWN position before the 
tape has stopped advancing, but power must not be removed 
from the system until all movement of the tape has ceased. 
The header switch should be guarded and shearwired in the 
DOWN position to allow normal operation. At the next 
calendar inspection the cassette should be replaced by 


following the same procedure. 


The HP cassette with the READ system software 1s 
inserted in the cassette compartment of the HP 9830. The 
data tape, which has been created by the WRITE system is 
loaded into the Memodyne read-only recorder. The READ/STORE 
program is currently on file number 1 and is loaded from the 
HP cassette to the HP 9830 memory by pressing LOAD1 and 
EXECUTE. If the data files have not been previously 
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formatted, it is necessary to do so by entering FIND2, 
Waiting for the tape to stop, and then entering MARK100,400. 
The calculator will commence marking file boundaries on the 
tape until it reaches the end of tape. The HP 9830 will 
Signal an error condition which indicates that it is unable 
to mark more files. Then press REWIND, RUN, and EXECUTE. 
The instructions to advance the data tape beyond its leader 
Will appear on the line printer. Hold the STOP key 
depressed, which will cause the data tape to advance. 
Release the STOP key when the last portion of the clear 
leader has advanced beyond the photoelectric sensing device, 
which is visible through a small hole to the right of the 
read head. For normal operation press CONT and EXECUTE. If 
no header is to be read, enter CONT1000 and EXECUTE. This 
is necessary when the portion of the tape with the header 
has already been read, and the data which follows does not 
have a header. When requested, enter the day, month and 
year in numerals separated by commas; then enter the number 
of 256-byte pages to be read. If a tape is to be read in 
its entirety, it is recommended that 25 pages be read. If 
there are less than 25 pages of data available, the data 
tape will reach its end and stop. The user must then press 
STOP, enter CONT2000, and press EXECUTE. [If there are more 
than 25 pages of data available, the program will reach a 
normal termination. To continue reading from the same data 
tape, an unused HP cassette must be placed in the HP 9830. 
The tape must be marked by entering MARK100,400 as _ before. 
When the files have been marked, press REWIND, RUN, and 
EXECUTE. This time the tape will not require the leader to 
be advanced, nor will the reading of the header be required. 
The program is continued by entering CONT1000 and pressing 


EXECUTE. 


a 


The File Retrieval program, located on file number 
zero, is loaded by entering LOADO and pressing EXECUTE. 


Program execution is commenced by pressing RUN and EXsCUTE. 


ty ty 





The program is continuous and requires the user to specify 
the channel to be examined. 


The current cassette data file system is adequate, 
but extremely slow in comparison to disk file systems. The 
HP 9830 may be equipped with a peripheral disk storage. It 
also may be feasible to tie the HP 9830 to a time-sharing 
system of a larger computer. The HP 9830 would serve as an 
intelligent terminal which would pre-process the input data 
and utilize the file system of the host computer. This 
would allow the retrieval and analysis of the iata on the 
larger computer; thus circumventing the disadvantages of the 
HP 9830 file system and taking full advantage of the larger 


computer's speed and storage capability. 
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Figure 4 - Flowchart: WRITE Program 
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Figure 5 - Flowchart: READ/STORE Program 
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Figure 6 - Flowchart: File Retrieval Program 
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APPENDIX A 


ToB WRETE SYSTEM SOFTWARE 


/*DECLARATIONS*/ 


DECLARE DCL LITERALLY ‘DECLARE? ; 


DCL 
DCL 
DCL 
DCL 
DCL 
DCL 
DCL 
DCL 
DCL 
DCL 
DCL 
DCL 
DCL 
DCL 


LIT LITERALLY 'LITERALLY'; 
(I,J,K) BYTE; 
(XX,LASTX,SIG,CHANNEL) BYTE; 
X(8) BYTE; 

XLST(8) BYTE; 

SLST(8) BYTE; 

FLAG(8) BYTE; 

C BYTE; 

RAMSLOC ADDRESS; 

EVENT BASED RAM$LOC BYTE; 
POSSTHRESH LIT '14H'; 
NEGSTHRESH LIT 'ODH'; 
FOREVER LIT 'WHILE OFFH'; 
TIMER ADDRESS; 
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mee ROC BDURES*/ 


DELAY: PROCEDURE(VAL) ; /*PROVIDES TIME DELAY*/ 
DCL VAL BYTE; 
CALL TIME(VAL) ; 

END DELAY; 


BYTE$RECORD: PROCEDURE; /*TRANSFERS ONE BYTE TO RECORDER*/ 
OUTPUT (2) =EVENT; 
OUTPUT (3) =08H; 
OUTPUT (3) =0; 
CALL DELAY (774); 
END BYTESRECORD; 


GAP:;PROCEDURE(N) ; /*WRITES BLANK SEGMENTS OF TAPE*/ 
DCL N BYTE; 
OUTPUT (3) =O4H; 
CALL DELAY (HN) ; 
OUTPUT (3) =0; 
END GAP; 


RECORD:PROCEDURE; /*RECORDS A BLOCK OF DATA*/ 
DCL COUNT ADDRESS; 
COUN T=RAMSLOC-— 1; 
DO RAMSLOC=0900H TO COUNT; 
Gael BYTESRECORD; 
END; 
CALL GAP (808) ; 
RAMSLOC=O08FFH; 
END RECORD; 





STORE: PROCEDURE; /¥*STORES A BYTE IN RAM*/ 
EVENT=NOT (LASTX OR ROR (CHANNEL,3)); /*PACKS WORD*/ 
FLAG (CHANNEL) = ((LASTX>POS$THRESH) 
OR (LASTX<NEGSTHRESH)) ; 
RAM$LOC=RAM$LOC+1; 
IF RAM$LOC>=1000H THEN CALL RECORD; /*MEMORY FULL*/ 
END STORE; 


READ: PROCEDURE BYTE; /*READS A THUMBWHEEL SWITCH*/ 
OUTPUT (2) =C; 
C=C+2; 
RETURN (INPUT(1) AND OFH) XOR OFH; 

END READ; 


HEADER: PROCEDURE; /*PREPARES TAPE FOR DATA KECORDING*/ 
DO K=1 TO 3; 
DO J=1 TO 150; 
CALL GAP (255); /*ADVANCES TAPE BEYOND LEADER*/ 
END; 
END; 


DO WHILE ROL (INPUT (1),3); /*WAIT FOR HEADER SWITCH OFF*/ 

END; 

C=0; 

DO RAMSLOC=0900H8 TO O904H; 
EVENT=80H; 

END; 

DO RAMS$LOC=0905H TO 0907H; 
EVENT=NOT (SHL(READ,4) +READ) ; 

END; 

RAMSLOC=0908H; 

CALL RECORD; 

RAMSLOC=0900H; 

END HEADER; 


56 





MUX:PROCEDURE; /*SEQUENTIALLY MONITORS CHANNELS*/ 
DEE L BYTE; 
OUTPUT (2) =40H; 
OUTPUT (2) =0; 
DO I=0 TO 7; 
OUTPUT (2) =1; 
OUTPUT (2) =0; 
DO WHILE NOT (ROL (INPUT (1),1)); 
END; 
K=INPUOT (0) ; 
OUTPUT (2) =80H; 
OUTPUT (2) =0; 
L=K AND O44; 
L=SHL (L, 1) ; 
K=K+L; 
X (I) =SHR (K, 3); 
END 
END MUX; 


MNCTLALIZE: PROCEDUREs /¥INITIALIZES SYSTEM*X/ 
RAMSLOC=0°900H; 
TINER=0; 
CALL MUX; 
DO CHANNEL=0 TO 7; 
XLST (CHANNEL) =X (CHANNEL) ; 
SLST (CHANNEL) =0; 
FLAG (CHANNEL) =0; 
END; 
BND INITIALIZE; 
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DUMP: PROCEDURE; /*RECORDS MEMORY RES IDUE*/ 
TIMER=TIMER+1; 
ITF TIMER<0O700H THEN RETURN; 
CALL RECORD; 
CALL INITIALIZE; 
END DUMP; 
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/*MAIN PROGRAM*/ 


CALL INITIALIZE; 


DO FOREVER; 
IF ROL(INPUT(1),3) THEN CALL HEADER; 
/*CHECK HEADER SWITCH*/ 
IP ROL(INPUT(1),4) THEN CALL DUMP; 
/*CHECK WEIGHT -ON-WOEELS (Sw itreue, 
ELSE TIMER=0; 


CALL MUX; 
DO CHANNEL=0 TO 7; 
IF (XX:=X (CHANNEL) ) <> (LASTX:=XLST (CHANNEL) ) THEN 
DO; 
IF XX>LASTX THEN SIG=OFFH; 
ELSE SIG=0; 
IF ((((LASTX>POSSTHRESH) OR (LASTX<NEGS$THRESH) ) 
OR FLAG (CHANNEL) ) 
AND (SIG XOR SLST(CHANNEL))) THEN CALL STORE; 
J*@ DETERMINE SIGNIFICANCE, 
XLST (CHANNEL) =XX; 
SLST (CHANNEL) =SIG; 
END; 
IF RAM$LOC=O08FFH THEN CALL INITIALIZE; 
END; 
END; 
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APPENDIX 3 


PL/M 


PL/M 1s a block-structured Language, which gives the 
program a modular appearance. The program has three obvious 
divisions: a series of declarations, a series of 
procedures, and the main program. The declarations are of 
two basic types: Variable declarations and literal 
declarations. The variable declarations identify variable 
hames to be used and the amount of memory storag2 each will 
reguire. The literal declarations are definitions assigned 
by the programmer; thus allowing the use of more descriptive 
program statements or shorthand notation for lengthy PL/M 


constructs. 


The procedures are individual blocks of code, which 
perform specialized functions and have names somewhat 
descriptive of that function. A procedure is invoked by a 
CALL <procedure name> statement from elsewhere in the 
program. After a procedure has performed its function, the 
execution of the program continues at the point from which 


the procedure was called. 


The main program is the starting point for the 
execution of the code. The main program is a series of 
executable steps, which performs various functions and 


invokes procedures to accomplish the program task. 


‘PL/M variables are either of type BYTE or type 
ADDRESS. BYTE variables are eight binary digits in length, 
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while ADDRESS Variables are sixteen bits long. ATi 
arithmetic or boolean operations which are performed are 
best understood if the binary representation of numbers is 
visualized. Hexadecimal numbers are easily converted to 
binary and are frequently used in PL/M programming. 
Hexadecimal numbers are distinguished by the letter H 
following the number. Binary numbers are identified by the 
suffix B and decimal numbers have no suffix. The dollar 
Sign has no significance in PL/M and may be used to separate 
characters where a blank space would be inappropriate. For 
example, the expression 0100$0100B is equivalent to 
01000100B. Use of the dollar sign frequently aids in the 


readability of the progran. 


The OUTPUT statement is of the form OUTPUT (<port 
number>) =<expression>. The expression represents an 8-bit 
pattern which corresponds to voltage levels to be latched in 
the output port whose number is indicated. For example, 

OUTPUT (2) =40H; 
is an instruction to latch voltage levels on lines 
corresponding to output port two in the pattern 010050000B 
(40H=0100$0000B) where 1 indicates a HIGH voltage and 0 
indicates a LOW voltage. The eight lines of output port two 
have a one-to-one correspondence with the bit positions. 
The leftmost bit corresponds to line 8 and the rightmost bit 
corresponds to line 1. In the example only line 7 would 


have a HIGH voltage. 


The use of INPUT instructions Gs Simnplapl yor 
example, 
X=INPUT (0) ; 
causes input port zero to be sampled and assigned to X as an 
8-bit binary number. Each bit in the number would indicate 
the status of the line to which it corresponds. If in the 


example, xX is found to be equal to 0001$0010B, then lines 
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two and five of input port zero have been determined to be 


the only lines at HIGH voltage. 


Most examinations of bit patterns in PL/M require 
some bit manipulation because logical tests of numbers 
involve only the rightmost bit. A shift causes a bit 
pattern to be offset in the direction indicated with vacated 
positions being filled with zero. For example, | 

SHR (011151011B, 3) 
causes the bit pattern to be shifted to the right by three 
bit positions with the vacated positions being filled with 
zeroes. The result would be 0000511118. The three 
rightmost bits are lost. The shift operation may also be 
performed to the left. 


The rotate operation is Similar to the shift 
operation except that the vacated positions are filled with 
the displaced bits from the opposite end. For example, 

ROL(110151000B,3) 
causes the bit pattern to be rotated left by three 
positions. The result is 1100$0110B where the three bits 
displaced at the left appear in the three positions which 
were vacated at the right. Tne use of the shift and rotate 
constructs allow any bit to be selectively placed in the 
rightmost position. The rotate operation may also be 


performed to the right. 


The IF <expression> and DO WHILE <expression> 
constructs require that the expression have a 1 in the 
Eightmost bit position in order for the test condition to be 
satisfied. For example, 

IF ROL(INPUT(1),3) THEN CALL HEADER; 
will result in a procedure call only if line 6 of input port 
one is examined and found at HIGH status. The use of NOT 
before ‘the expression would result in the procedure call 


being invoked only if line 6 were found to be at LOW status. 


62 


| - 
—) So 
a4 
° 
7 
_ 
> _ 
5 
» 
7 -_ 
7 
' UL 
> 
ae a 
- 77 
Pe oi 
an 





» @s 





The DO WHILE <expression> causes the current block 
of code to be repetitively executed while the rightmost bit 
of the expression is a 1. The use of NOT before the 
expression causes the execution to continue while the 
Cightmost bit is zero. For example, 

DO WHILE NOT (ROL(INPUT(1),1)); 

X=X+1; 

END; 
causes X to be incremented until line 8 of input port one is 
HIGH. 


The AND, OR, and XOR operators perform the boolean 
operations "and", "inclusive or", and "exclusive OE 
respectively bit-by-bit on their arguments. For 2xample, 

0111$0100B AND 1111$00003B 
results in 0111$0000B. This operation is frequently used to 


isolate or mask a portion of the bit pattern. 
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100 
110 
120 
130 
140 
150 
160 
170 
180 
190 
200 
210 
220 
230 
240 
250 
260 
270 
280 
290 
400 
410 
420 
430 
Y4Q 


APPENOZX C 


THE READ SYSTEM SOFTWARE PACKAGE 


The READ/STORE Program 


DIM A[100],B{ 100 }],C[ 100 ]}, D{ 100] 

DIM E(100],F(100 ],G{[ 100 },H[ 100] 

DIM L[{100],Y{ 100 j,2{ 256] 

MAT Y=CON 

MAT Y=(100) *¥ 

MAT A=Y¥ 

MAT B=Y 

MAT C=Y 

MAT D=¥ 

MAT E=Y 

MAT FP=Y¥ 

MAT G=¥ 

MAT H=Y 

MAT Z=ZER 

MAT L=ZER 

PRINT "ADVANCE TAPE BEYOND CLEAR LEADER" 
PRINT "BY HOLDING ‘STOP!’ KEY DEPRESSED" 
PRINT "THEN PRESS ‘CONT! ‘EXECUTE! "LIN2 
STOP 

R BM & 2 2 4 2 2 He a XE Xe KE OK EK WK XE EC Oe ee KE KK KK XO KK KE KK KOK Ke OK KK KOK KK 
DISP "ENTER DA,MO,YR",SPA20; 

INPUT N1,N2,N3 

FOR N=1 TO 8 

Z{ N]=RBYTE7 

NEXT W 
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450 
460 
470 
480 
490 
500 
5190 
520 
530 
540 
550 
560 
1000 
1010 
1020 
1030 
1040 
1050 
1060 
1070 
1080 
1090 
1100 
1110 
20 
1130 
1140 
1150 
1160 
1170 
2000 
20 10 
2020 
2030 
2040 
2050 


M0=0 

FOR N=6 TO 8 
M0=100*M0 
M1=BIAND (Z[N J, 240) 
M1=ROT (M1, 4) 
M1=10*M1 

MO=MO+M1 

M1=BIAND (Z[{N], 15) 
MO=M0O+4M1 

NEXT N 

PRINT "BUNO="";M40,"DA/MO/YR="3;N1,N2,N3 


Ove te tes SSS SS ES SS SSS SSS tS LSS SESS PES SS PSE StS SES StS FS > 


N=N 1=N2=N3=N4=N5=N6=N 7=N8=1 

MO=M1=2 

DISP "ENTER NO. OF PAGES TO BE READ"SPAS; 
INPUT P 


FOR K=1 TO P 

FOR I=1°TO 256 

Z{( L J=RBYTE7 

NEXT I 

FOR I=1 TO 256 

J=BIAND(Z[ I], 224) 

J=ROT (3,5) 

J=J3 +1 

V=BIAND (Z{ I], 31) 

V=V-16 

GOSUB J OF 4100,4200,4300,4400,4500,4600,4700, 4800 
NEXT I 

NEXT K 

REM % 2 6 2 5 HE EK 2 2 AEH RC 2 2 ee 2 KO 2 AE 2 Ca 2 A 2 KK OK OK 
V=100 

N1=N2=N 3=N4=N 5=N6=N7=N8=100 

POR J=1 TO 8 

GOSUB J OF 4100,4200,4300,4400,4500,4600,4700,4800 
NEXT J 

STORE DATA MO,L 
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2060 
2070 
2080 
4100 
4110 
4120 
4140 
4150 
4180 
4190 
4199 
4200 
4210 
4220 
G240 
4250 
4280 
4290 
4299 
4300 
4310 
4320 
4340 
4350 
4380 
4390 
4399 
GUOO0 
4410 
4420 
U440 
4450 
4u8Q 
4490 
4499 
4500 


REWIND 
SLO 


REM % 6 2 2 2 He he a ae he he he ee ee A he he hc hee hee oe He He He Oe ie ee he ee He oe He oe aK oe aK A KK OK 


AL N1J=V 

NI=N1+1 

IF N1#101 THEN 4199 
GOSUB 7000 

SLORE DATA WTA 
N1=1 

MAT A=Y 

RETURN 

BL N2]=V 

N2=N2+1 

IP N2#101 THEN 4299 
GOSUB 7000 

STORE DATA M1,B 
N2=1 

MAT B=Y 

RETURN 

C{N3 J=V 

N3=N3+1 

IF N34101 THEN 4399 
GOSUB 7000 

STORE DATA M1,C 
N3=1 

MAT C=Y 

RETURN 

DI NY J=V 

NG=NGQ+1] 

IF N4#101 THEN 4499 
GOSUB 7000 

STORE DATA M1,D 
NG=1 

MAT D=Y 

RETURN 

E( N5 J=V 
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4510 
4520 
4540 
4550 
4580 
4590 
4599 
4600 
4610 
4620 
4640 
4650 
4680 
4690 
4699 
4700 
4710 
4720 
474Q 
4750 
4780 
4790 
4799 
4800 
4810 
4820 
484Q 
4850 
4880 
4890 
4899 
4900 
7000 
7010 
7020 
7030 


NS=N5+1 

IF N54#101 
GOSUB 7000 
STORE DATA M1,E 
N5=1 

MAT E=Y 

RETURN 

PL N6 J=V 

NO=N6+1 

IF N6#101 THEN 4699 
GOSUB 7000 

STORE DATA M1,F 
N6=1 

Man Pay 
RETURN 

G{ N71 ]=V 
N7=N7+1 

IF N7#101 
GOSUB 7000 
SrOksS DATA NU7S 
N7=1 

MAT G=Y 
RETURN- 

H( N8.J=V 
N3=N8+1 

IF N8#4101 
GOSUB 7000 
STORE DATA 41,4 
N8=1 

MAT H=Y 

RETURN 


THEN 4599 


THEN 4799 


THEN 4899 


R PM Rk Ok a a kk tk kk a tok ke 


L{ N J=Jd 
N=N+1 

M1=41+1 
RETURN 
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The File Retrieval Program 


10 DIM L{ 100 j],xX[ 100] 

20 M=2 

30 LOAD DATA 4M,L 

So PRINT LIN2 

40 DISP "ENTER CHANNEL NO. (1-8)"; 

50 INPUT C 

SOePRINT “CHANNEL";:C, LIN? 

70 FOR N=1 TO 100 

80 IF L{N]#C THEN 90 

85 GOSUB 120 

90 IF L{N]=0 THEN 35 

SoeNEXT WN 

QQ REM 262 36 2 Fe He He aE SE a RC He 2 CC RII 2 a oe 2 2 OK i eo 2 2 ok 

120 LOAD DATA NtM,X 

7130 FOR I=1 TO 91 STEP 10 

ome RUNT X[{ I )sxX{ r+? ]SxX{[ 1+2 ];3 x 2£+3 J; X[ 2t4 J; (Eto), Xi Eee, 
Xt ees oe a eo 

150 NEXT I 

160 PRINT 

170 RETURN 
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APPENDIX D 


BASIC 


The statements of a program written in BASIC are 
executed sequentially in the numerical order of their 
Statement numbers. The storage of variables is allocated 
upon initial use of the variable with the exception of 
arrays. Array storage must be declared in advance by the 


use of the DIM (dimension) statement. 


The main program follows the DIM statements and any 
initialization statements which might be required. The main 
program is followed by the procedural subroutines. A 
subroutine is delimited by its beginning statement number 
and an ending RETURN statement. A subroutine is invoked by 
a GOSUB <beginning Statement number> statement from 
elsewhere in the program. The RETURN statement causes the 
program to resume with the next statement following the 


GOSUB statement. 


All numbers appearing in BASIC are decimal numbers. 

Bat Manipulative operations return the decimal 
representation of the 8-bit binary result. The boolean 
Nand" is expressed as 

X=BIAND (A,B) 
and causes X to be assigned the decimal value of the binary 
result OF the Dit-by-bit Nand"-ing of the binary 
representation of A with the binary representation of BB. 
For example, 

X= BIAND (14,9) 
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1s equivalent to X=000051110B AND 0000$1001B=0000$1000B and 
would result in X=8. Similarly the ROT statement is used for 
right rotation. The statement 

X=ROT (A, B) 
causes X to be assigned the decimal value of the binary 
result of the rotation of the bit pattern of A to the right 
for B positions. For example, 

k= ROT (ies) 
1s equivalent to the rotation of 0001$0001B to the right for 
three poSitiocns which results in x=0010$0010B=34. 


The prefix MAT identifies a statement aS a matrix 

operation. The statement 

MAT A=ZER 
causes all elements of the array A to be set equal to zero. 
The statement 

MAT B=CON 
Causes all elements of array B to be set equal to one. The 
statement 

MAT X=Y 
Causes each element of array xX to be set equal to the 


corresponding element of array Y. 


The PRINT statement is used to output information on 
the peripheral line printer. The display command (DISP) 
causes a line to be output in the display window above the 
keyboard. Blank spaces or lines may be indicated by using 


SPA or LIN followed by a number. 


The INPUT command interruptS execution of the 
program and awaits the input of data by the user at the 
keyboard. The statement 

INPUT A,B 
causes anticipation of a user response. For exanple, a user 
response of 

E66 oe boon LT E> 
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assigns values of 4 and 6.5 to variables A and B 


respectively before continuing program execution. 


The conditional IF <argument> THEN <statement 
number> causes the program execution to be diverted to the 
statement number following THEN if the argument following IF 
1s a true statement. For example, 

IF X<6 THEN 100 
resuits in program branching to statement 100 only if the 


variable X is currently less than 6. 


Another powerful conditional branching statement is 
the GOSUB <expression> OF <statement number list> statement. 
The value of the expression is an ordinal number, which 
Causes the execution of the program to branch to the 
statement number appearing in the corresponding position in 
the list of statement numbers. For example, 

K=3 
GOSUB X OF 100,150,200,250 
would cause the subroutine located at line 200 to be 


executed. 


1) 
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